<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org" xmlns:sec="http://www.thymeleaf.org/thymeleaf-extras-springsecurity5">
<head>
    <meta charset="UTF-8">
    <title>权限管理--右边列表</title>
    <meta content="webkit" name="renderer">
    <meta content="IE=edge,chrome=1" http-equiv="X-UA-Compatible">
    <meta content="*" http-equiv="Access-Control-Allow-Origin">
    <meta content="width=device-width, initial-scale=1, maximum-scale=1" name="viewport">
    <meta content="black" name="apple-mobile-web-app-status-bar-style">
    <meta content="yes" name="apple-mobile-web-app-capable">
    <meta content="telephone=no" name="format-detection">
    <link rel="icon" th:href="@{/favicon.ico}">
    <link media="all" rel="stylesheet" th:href="@{/layui/css/layui.css}"/>
    <link media="all" rel="stylesheet" th:href="@{/css/public.css}"/>
    <link media="all" rel="stylesheet" th:href="@{/layui_ext/dtree/dtree.css}"/>
    <link media="all" rel="stylesheet" th:href="@{/layui_ext/dtree/font/dtreefont.css}"/>

</head>
<body class="childrenBody" sec:authorize="hasPermission('/admin/permission/toPermissionManager',null)">
<!-- 查询条件开始 -->
<blockquote class="layui-elem-quote">
    <form action="" class="layui-form layui-form-pane" id="searchFrm" lay-filter="searchFrm" method="post">
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">权限名称</label>
                <div class="layui-input-inline">
                    <input autocomplete="off" class="layui-input" name="title" type="text">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">权限编码</label>
                <div class="layui-input-inline">
                    <input autocomplete="off" class="layui-input" name="percode" type="text">
                </div>
                <div class="layui-input-inline">
                    <button class="layui-btn" lay-filter="doSearch" lay-submit="" type="button"><span
                            class="layui-icon layui-icon-search"></span>查询
                    </button>
                    <button class="layui-btn layui-btn-warm" type="reset"><span
                            class="layui-icon layui-icon-refresh-1"></span>重置
                    </button>
                </div>
            </div>
        </div>
    </form>
</blockquote>
<!-- 查询条件结束-->


<!-- 数据表格开始 -->
<div>
    <table class="layui-hide" id="permissionTable" lay-filter="permissionTable"></table>
    <div id="permissionToolBar" style="display: none;">
        <button class="layui-btn layui-btn-sm" lay-event="add" type="button" sec:authorize="hasPermission('/admin/permission/addPermission','permission:add')">
            <span class="layui-icon layui-icon-add-1"></span>添加权限
        </button>
    </div>

    <div id="permissionRowBar" style="display: none;">
        <button class="layui-btn layui-btn-sm" lay-event="update" type="button" sec:authorize="hasPermission('/admin/permission/updatePermission','permission:update')">
            <span class="layui-icon layui-icon-edit"></span>更新
        </button>
        <button class="layui-btn layui-btn-sm layui-btn-danger" lay-event="delete" type="button" sec:authorize="hasPermission('/admin/permission/deletePermission','permission:delete')">
            <span class="layui-icon layui-icon-delete"></span>删除
        </button>
    </div>
</div>

<!-- 数据表格结束 -->

<!-- 添加和修改的弹出层开始 -->
<div id="addOrUpdateDiv" style="display: none;padding: 5px" sec:authorize="hasPermission('/admin/permission/addPermission','permission:add') || hasPermission('/admin/permission/updatePermission','permission:update')">
    <form action="" class="layui-form layui-form-pane" id="dataFrm" lay-filter="dataFrm" method="post">
        <div class="layui-form-item">
            <label class="layui-form-label">选择菜单</label>
            <div class="layui-input-block">
                <input id="pid" lay-verify="required" name="pid" type="hidden">
                <ul class="dtree" data-id="0" id="permissionTree"></ul>
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">权限名称</label>
            <div class="layui-input-block">
                <input name="id" type="hidden">
                <input autocomplete="off" class="layui-input" lay-verify="required" name="title" placeholder="请输入权限名称"
                       type="text">
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">权限编码</label>
            <div class="layui-input-block">
                <input autocomplete="off" class="layui-input" name="percode" placeholder="请输入权限编码" type="text">
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">菜单地址</label>
            <div class="layui-input-block">
                <input autocomplete="off" class="layui-input" name="href" placeholder="请输入菜单地址" type="text">
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">是否可用</label>
                <div class="layui-input-inline">
                    <input checked="" name="available" title="可用" type="radio" value="1">
                    <input name="available" title="不可用" type="radio" value="0">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: center;">
                <button class="layui-btn" id="doSubmit" lay-filter="doSubmit" lay-submit="" type="button"><span
                        class="layui-icon layui-icon-add-1"></span>提交
                </button>
                <button class="layui-btn layui-btn-warm" type="reset"><span
                        class="layui-icon layui-icon-refresh-1"></span>重置
                </button>
            </div>
        </div>
    </form>
</div>
<!-- 添加和修改的弹出层结束 -->


<script th:src="@{/layui/layui.js}" type="text/javascript"></script>
<script type="text/javascript">
    var tableIns;
    layui.extend({
        dtree: '../../layui_ext/dtree/dtree'   // {/}的意思即代表采用自有路径，即不跟随 base 路径
    }).use(['jquery', 'form', 'table', 'layer', 'dtree'], function () {
        var $ = layui.jquery;
        var form = layui.form;
        var table = layui.table;
        var layer = layui.layer;
        var dtree = layui.dtree;
        //加载 数据
        tableIns = table.render({
            elem: '#permissionTable'
            , url: '/admin/permission/loadAllPermission'
            , toolbar: '#permissionToolBar' //开启头部工具栏，并为其绑定左侧模板
            , title: '权限数据表'
            , page: true
            , cols: [ [
                {field: 'id', title: 'ID', align: 'center',width:'80'}
                , {field: 'pid', title: '菜单ID', align: 'center',width:'100',hide:true}
                , {field: 'pname', title: '菜单名', align: 'center',width:'150'}
                , {field: 'title', title: '权限名称', align: 'center',width:'150'}
                ,{field:'href', title:'菜单地址',align:'center',width:'330'}
                , {field: 'percode', title: '权限编码', align: 'center',width:'160'}
                , {
                    field: 'available', title: '是否可用', align: 'center',width: '100', templet: function (d) {
                        return d.available == 1 ? '<span style="color: blue">可用</span>' : '<span style="color: red">不可用</font>';
                    }
                }
                , {fixed: 'right', title: '操作', toolbar: '#permissionRowBar', align: 'center', width: '200'}
            ] ]
            , done: function (res, curr, count) { //处理删除某一页最后一条数据的BUG
                if (res.data.length == 0 && curr != 1) {
                    tableIns.reload({
                        page: {
                            curr: (curr - 1)
                        }
                    });
                }
            }
        });
        //关闭下拉框
        $("body").on("click", function (event) {
            $("div[dtree-id][dtree-select]").removeClass("layui-form-selected");
            $("div[dtree-id][dtree-card]").removeClass("dtree-select-show layui-anim layui-anim-upbit");
        });

        //模糊查询
        form.on("submit(doSearch)", function (data) {
            tableIns.reload({
                where: data.field,
                page: {
                    curr: 1
                }
            });
            return false;
        });

        //监听工具条的事件
        table.on("toolbar(permissionTable)", function (obj) {
            switch (obj.event) {
                case 'add':
                    openAddLayer();
                    break;
            }
            ;
        });

        //监听行工具条的事件
        table.on("tool(permissionTable)", function (obj) {
            var data = obj.data; //获得当前行数据
            switch (obj.event) {
                case 'update':
                    openUpdatePermissionLayer(data);
                    break;
                case 'delete':
                    deletePermission(data);
                    break;
            }
            ;
        });

        var mainIndex;
        var url;

        //打开添加的弹出层
        function openAddLayer() {
            mainIndex = layer.open({
                type: 1,
                content: $("#addOrUpdateDiv"),
                area: ['800px', '600px'],
                title: '添加权限',
                success: function () {
                    $("#dataFrm")[0].reset();
                    $("#pid").val("");
                    url = "/admin/permission/addPermission";
                    selectTree.selectVal("");
                }
            });
        }

        //打开修改的弹出层
        function openUpdatePermissionLayer(data) {
            mainIndex = layer.open({
                type: 1,
                content: $("#addOrUpdateDiv"),
                area: ['800px', '600px'],
                title: '修改权限',
                success: function () {
                    $("#dataFrm")[0].reset();
                    //装载新的数据
                    form.val("dataFrm", data);
                    //选中之前父级的权限  nodeId=data.pid;
                    dtree.dataInit("permissionTree", data.pid);
                    dtree.selectVal("permissionTree");
                    url = "/admin/permission/updatePermission";
                }
            });
        }

        form.on("submit(doSubmit)", function (data) {
            $.post(url, data.field, function (res) {
                if (res.code == 200) {
                    tableIns.reload();
                }
                layer.msg(res.msg);
                layer.close(mainIndex);
            })
            return false;
        })

        //删除
        function deletePermission(data) {
            layer.confirm('你确定要删除【' + data.title + '】这条权限吗?', {icon: 3, title: '提示'}, function (index) {
                $.post("/admin/permission/deletePermission", {id: data.id}, function (res) {
                    if (res.code == 200) {
                        tableIns.reload();
                    }
                    layer.msg(res.msg);
                })
                layer.close(index);
            });
        }

        //初始化下拉树
        var selectTree = dtree.renderSelect({
            elem: "#permissionTree",
            width: "100%", // 可以在这里指定树的宽度来填满div
            dataStyle: "layuiStyle",  //使用layui风格的数据格式
            dataFormat: "list",  //配置data的风格为list
            response: {message: "msg", statusCode: 0},  //修改response中返回数据的定义
            url: "/admin/permission/loadPermissionManagerLeftTreeJson" // 使用url加载（可与data加载同时存在）
        });
        //监听点击的方法
        dtree.on("node(permissionTree)", function (obj) {
            $("#pid").val(obj.param.nodeId);
            //console.log(obj.param.nodeId); // 点击当前节点传递的参数
        });
    });

    //给其它页面刷新当前页面数据表格的方法
    function reloadTable(id) {
        tableIns.reload({
            where: {
                id: id
            },
            page: {
                curr: 1
            }
        });
    }
</script>

</body>
</html>